<?php

declare(strict_types=1);

namespace app\common\dao\sys;

use app\common\model\sys\SysUserRole;
use app\common\traits\DaoTrait;

/**
 * 用户角色关联表
 * @author:kaige
 * @update:2022-06-12
 * @copyright ©2022 泉州市盛筑信息科技有限公司 版权所有
 */
class UserRoleDao
{
  // 当前操作的模型
  protected $model = null;

  // 对应模型的主键，默认为id
  protected $pk = 'id';

  // 对应模型默认查询的字段
  protected $name = 'user_id';

  // 对应模型允许查询的字段(默认全部查询)
  protected $allowField = ['*'];

  // 允许单字段更新
  protected $uaField = [];

  // 查询结果-要隐藏的字段 默认空数组
  protected $hideField = [];

  public function __construct()
  {
    $this->model = new SysUserRole();
  }
  use DaoTrait;

  /**
   * 根据user_id清空用户角色
   */
  public function clearUserId($uid)
  {
    return $this->model->where('user_id', $uid)->delete();
  }

  /**
   * 保存用户角色
   */
  public function saveAllUserRole($data)
  {
    return $this->model->saveAll($data);
  }

  /**
   * 获取此用户所有角色ID
   */
  public function getUserRoleAllId($user_id = 0)
  {
    return $this->model->where('user_id', $user_id)->column('role_id');
  }

  /**
   * 获取此角色所有用户ID
   */
  public function getRoleAllUserId($role_id = 0)
  {
    return $this->model->where('role_id', $role_id)->column('user_id');
  }
}
